<template>
  <view class="container">
    <view class="content"
          style="padding-bottom:200upx;">
      <view class="order-list-box"
            v-for="(item,index) in retundlist"
            :key="index">
        <view class="item">
          <view class="order-info-box">
            <view class="order-info">
              <view class="order-info-item">
                <image :src="item.image"
                       class="product-img"></image>
                <view class="info-box">
                  <text class="product-name">{{ item.productName }}</text>
                  <view class="product-sku">{{ item.value }}</view>
                  <view class="price-sku-box">
                    <text class="product-price">
                      <text class="fuhao">￥</text>
                      {{ item.price }}
                    </text>
                    <text class="product-num">x {{ item.number }}</text>
                  </view>
                </view>
              </view>
            </view>
          </view>
        </view>
      </view>

      <view class="afterSale-select-box">
        <view class="item"
              @click="openStatusSelect">
          <view class="l">货物状态</view>
          <view class="r-box"
                v-model="ReturnMoneyQuery.goodsState"
                v-if="ReturnMoneyQuery.goodsState == 0">
            <text>未收到货</text>
            <image src="https://ceres.zkthink.com/static/images/arrowRight.png"
                   class="r"></image>
          </view>
          <view class="r-box"
                v-model="ReturnMoneyQuery.goodsState"
                v-if="ReturnMoneyQuery.goodsState == 1">
            <text>已收到货</text>
            <image src="https://ceres.zkthink.com/static/images/arrowRight.png"
                   class="r"></image>
          </view>
        </view>
        <view class="item"
              @click="openReasonSelect">
          <view class="l">退款原因</view>
          <view class="r-box">
            <text v-model="ReturnMoneyQuery.returnReason">{{ liyoutext }}</text>
            <image src="https://ceres.zkthink.com/static/images/arrowRight.png"
                   class="r"></image>
          </view>
        </view>
      </view>

      <view class="afterSale-select-box mt20">
        <view class="item">
          <view class="l">退款金额：
            <text class="order-status">¥ {{ sellPriceitem.toFixed(2) }}</text>
          </view>
        </view>
        <view class="item item-start">
          <view class="l">退款说明：</view>
          <view class="r-box r-box2">
            <input v-model="ReturnMoneyQuery.returnDesc"
                   type="text"
                   placeholder="选填"
                   class="r-box-input"></input>
          </view>
        </view>
      </view>

      <view class="afterSale-select-box mt20">
        <view class="upload-title">上传凭证</view>
        <view class="mar-left-10 mar-top-10">
          <u-upload :limitType="['png', 'jpg', 'jpeg', 'webp', 'gif', 'image']"
                    max-count="4"
                    :action="action"
                    ref="uUpload"
                    :header="headerToken"
                    :form-data="formData"></u-upload>
        </view>
      </view>

      <view class="order-flow-box">
        <view class="flow-word">退款流程：</view>
        <view class="flow-word mt25">
          <text>1、退货说明并提交</text>
          <text>2、2天内等待卖家处理，超时默认同意退款</text>
          <text>3、卖家同意，退款金额原路退还</text>
        </view>
        <view class="flow-word mt50">注：退款金额以实际支付价格为准</view>
      </view>
    </view>

    <view class="order-confirm-box"
          style="padding-top:30upx;"
          :style="{'padding-bottom':(isIphone==true? 90:0)+'rpx'}">
      <text class="btn"
            @click="confirmTap">提交
      </text>
    </view>

    <!-- 货物状态弹框 -->
    <u-popup v-model="cargoStatusShowFalg"
             mode="center"
             border-radius="14"
             width="80%"
             closeable="true">
      <view class="alert-box">
        <view class="afterSale-status-box">
          <view class="status-title">货物状态</view>
          <view class="item-box">
            <view class="item"
                  @click="ReturnMoneyQuery.goodsState = 0">
              <text class="status-select-title">未收到货</text>
              <image mode="aspectFill"
                     src="https://ceres.zkthink.com/static/images/selectActive.png"
                     v-if="ReturnMoneyQuery.goodsState == 0"
                     class="status-select-img"></image>
              <image mode="aspectFill"
                     src="https://ceres.zkthink.com/static/images/selectEmpty.png"
                     v-else
                     class="status-select-img"></image>
            </view>
            <view class="item"
                  @click="ReturnMoneyQuery.goodsState = 1">
              <text class="status-select-title">已收到货</text>
              <image mode="aspectFill"
                     src="https://ceres.zkthink.com/static/images/selectActive.png"
                     v-if="ReturnMoneyQuery.goodsState == 1"
                     class="status-select-img"></image>
              <image mode="aspectFill"
                     src="https://ceres.zkthink.com/static/images/selectEmpty.png"
                     v-else
                     class="status-select-img"></image>
            </view>
          </view>
          <view class="status-btn"
                @click="closeStatusSelect">确定
          </view>
        </view>
      </view>
    </u-popup>
    <!-- 退款原因弹框 -->
    <!-- 退款原因弹框 -->
    <u-popup v-model="reasonShowFalg"
             mode="center"
             border-radius="14"
             width="80%"
             closeable="true">
      <view class="alert-box">
        <view class="afterSale-status-box"
              scroll-y>
          <view class="status-title">退款原因</view>
          <view class="item-box">
            <view class="item"
                  @click="returnReasonTap(item,index)"
                  v-for="(item,index) in liyouData"
                  :key="index">
              <text class="status-select-title">{{ item }}</text>
              <image mode="aspectFill"
                     src="https://ceres.zkthink.com/static/images/selectActive.png"
                     v-if="ReturnMoneyQuery.returnReason == index"
                     class="status-select-img"></image>
              <image mode="aspectFill"
                     src="https://ceres.zkthink.com/static/images/selectEmpty.png"
                     v-else
                     class="status-select-img"></image>
            </view>
          </view>
          <view class="status-btn"
                @click="closeReasonSelect">确定
          </view>
        </view>
      </view>
    </u-popup>
  </view>
</template>

<script>
const NET = require('../../utils/request')
const API = require('../../config/api')
export default {
  data() {
    return {
      returnImgsList: 1,
      cargoStatusShowFalg: false,
      reasonShowFalg: false,
      returnReasonIndex: 1,
      item: {},
      ReturnMoneyQuery: {
        goodsState: 1,
        orderCode: "",
        orderProductIds: "",
        refundFee: 0,
        returnDesc: "",
        returnImgs: "",
        returnReason: 0,
        returnType: 0
      },
      action: API.UploadUrl,
      formData: {'folderId': -1},
      headerToken: {Authorization: ''},
      fileList: [],
      sellPriceitem: 0,//退款价格
      listitemid: '',	//选中商品的id
      orderCode: '',	// 选中订单编码

      liyouData: [],
      liyoutext: '',
      liyouindex: '',
      retundlist: [],
      orderId: 0,
      isIphone: false,
      isAllSelect: 0,
    }
  },
  onReady() {
    this.isIphone = getApp().globalData.isIphone;
    this.fileList = this.$refs.uUpload.lists
  },
  async onLoad(option) {
    this.retundlist = JSON.parse(decodeURIComponent(option.list))
    console.log(option,'this.retundlist')

    this.orderId = option.orderId
    this.isAllSelect = option.isAllSelect
    // console.log(this.retundlist, 'retundlist')
    this.retundlist.forEach(el => {
      this.sellPriceitem = this.sellPriceitem + el.number * el.price
    })
    this.getReasonEnums()
    this.sellPriceitem = await this.HandleGetRefundMoney()
  },
  methods: {
    // 算钱
    HandleGetRefundMoney() {
      return new Promise((resolve, reject) => {
        uni.showLoading({
          title: "计算中..."
        })
        let postData = {
          orderId: this.orderId,
          isAllSelect: this.isAllSelect==1 ? 1 : 0,
          skus: this.retundlist,
          afterType:2,
          goodsState:this.ReturnMoneyQuery.goodsState
        }
        NET.request(API.GetRefundMoney, postData, "POST").then(res => {
          uni.hideLoading()
          resolve (parseFloat(res.json))
        }).catch(err=>{
          uni.hideLoading()
        })
      })
    },
    confirmTap() {
      if (this.fileList.length > 0) {
        this.commentImgsFlag = true
        for (let i = 0; i < this.fileList.length; i++) {
          this.commentImgs += this.fileList[i].response.data.url + ','
        }
      }
      this.ReturnMoney()
    },
    getReasonEnums() {
      NET.request(API.ReasonEnums, 'GET').then(res => {
        this.liyouData = res.data
        this.liyoutext = this.liyouData[0]
      }).catch(res => {
      })
    },
    ReturnMoney() {
      if (this.ReturnMoneyQuery.goodsState === '') {
        uni.showToast({
          title: '请选择货物状态！',
          duration: 2000,
          icon: 'none'
        });
      } else if (this.liyoutext === '') {
        uni.showToast({
          title: '请选择退货原因！',
          duration: 2000,
          icon: 'none'
        });
      } else {
        uni.showLoading({
          mask: true,
          title: '正在提交...',
        })
        let skusobjdata = []
        this.retundlist.forEach((i) => {
          let skusobj = {}
          skusobj["skuId"] = i.skuId
          skusobj["number"] = i.number
          skusobjdata.push(skusobj)
        })
        NET.request(API.ApplyReturnMoney, {
          orderId: this.orderId,
          afterType: 2,
          goodsState: this.ReturnMoneyQuery.goodsState,
          price: this.sellPriceitem,
          returnReason: this.liyoutext,
          explain: this.ReturnMoneyQuery.returnDesc,
          image: this.commentImgs,
          skus: skusobjdata,
          isAllSelect: this.isAllSelect
        }, 'POST').then(res => {
          uni.hideLoading()
          uni.showToast({
            title: '提交成功'
          })
          uni.navigateTo({
            url: '../../pages_category_page2/orderModule/afterSale'
          })
        }).catch(res => {
          uni.showToast({
            title: '商品已在售后，请勿重新操作！',
            duration: 2000,
            icon: 'none'
          });
          uni.hideLoading()
        })
      }
    },
    // 理由
    returnReasonTap(item, index) {
      this.ReturnMoneyQuery.returnReason = index
      this.liyoutext = item
    },

    openStatusSelect() {
      this.cargoStatusShowFalg = true
    },
    openReasonSelect() {
      this.reasonShowFalg = true
    },
    async closeStatusSelect() {
      this.cargoStatusShowFalg = false
      this.sellPriceitem = await this.HandleGetRefundMoney()
    },
    closeReasonSelect() {
      this.reasonShowFalg = false
    },

  }
}
</script>

<style lang="scss">
.content {
  padding: 0 0 120upx;
  box-sizing: border-box;
}

.order-list-box {
  padding: 20upx 30upx;
  box-sizing: border-box;
}

.order-list-box .item {
  /* margin-bottom: 20upx; */
  background: #fff;
  border-radius: 10upx;
}

.order-list-top {
  height: 96upx;
  padding: 0 30upx;
  box-sizing: border-box;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid #eee;
}

.top-l {
  display: flex;
  flex-direction: row;
  align-items: center;
}

.shop-img {
  width: 36upx;
  height: 36upx;
  margin-right: 10upx;
}

.shop-name {
  font-size: 30upx;
  color: #333;
  font-weight: bold;
}

.arrow-img {
  margin-left: 15upx;
  width: 24upx;
  height: 24upx;
}

.order-status {
  font-size: 28upx;
  color: #C83732;
  font-weight: 500;
}

.order-info-box {
  padding: 0 30upx;
  box-sizing: border-box;
}

.order-info {
  /* border-bottom: 1px solid #eee; */
}

.order-info-item {
  display: flex;
  flex-direction: row;
  padding: 20upx 0;
  border-bottom: solid 1px #eee;
}

.order-info-item:last-child {
  border-bottom: none;
}

.product-img {
  width: 180upx;
  height: 180upx;
  border-radius: 10upx;
  margin-right: 30upx;
}

.info-box {
  flex: 1;
  display: flex;
  flex-direction: column;
}

.product-name {
  font-size: 26upx;
  color: #333;
  height: 68upx;
  line-height: 34upx;
  display: -webkit-box;
  overflow: hidden;
  text-overflow: ellipsis;
  word-break: break-all;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.price-sku-box {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
}

.product-sku {
  font-size: 24upx;
  color: #999;
  margin-top: 30upx;
}

.product-price {
  font-size: 28upx;
  color: #333;
  font-weight: 400;
}

.product-price .fuhao {
  font-size: 28upx;
}

.product-num {
  font-size: 28upx;
  color: #999;
}

.afterSale-select-box {
  width: 100%;
  background: #fff;
  padding: 0 30upx;
  box-sizing: border-box;
}

.afterSale-select-box .item {
  height: 100upx;
  border-bottom: 1px solid #e5e5e5;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  font-size: 28upx;
  color: #333;
}

.afterSale-select-box .item:last-of-type {
  border-bottom: none;
}

.afterSale-select-box .item.item-start {
  justify-content: flex-start;
}

.afterSale-select-box .item .l {
  display: flex;
  flex-direction: row;
  align-items: center;
}

.afterSale-select-box .item .afterSale-img {
  width: 26upx;
  height: 26upx;
  margin-right: 20upx;
}

.afterSale-select-box .item .r-box {
  display: flex;
  flex-direction: row;
  align-items: center;
  color: #999;
}

.afterSale-select-box .item .r-box2 {
  width: 100%;
  flex: 1;
}

.afterSale-select-box .item .r {
  width: 24upx;
  height: 24upx;
  margin-left: 10upx;
}

.afterSale-select-box .line {
  border-bottom: 1px solid #e5e5e5;
}

.mt20 {
  margin-top: 20upx;
}

.r-box-input {
  text-align: left;
  flex: 1;
  z-index: 0;
}

.upload-title {
  font-size: 28upx;
  color: #333;
  padding: 30upx 0;
}

.upload-img-box {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  padding: 0 0 30upx;
  align-items: flex-start;
}

.upload-img-box .single {
  display: flex;
  flex-direction: row;
  align-items: flex-end;
}

.upload-img-box .upload-img-item-box {
  position: relative;
}

.upload-img-box .upload-img-item {
  width: 150upx;
  height: 150upx;
  border-radius: 8upx;
  margin: 0 50upx 30upx 0;
}

.upload-img-box .upload-img-item:nth-of-type(3n) {
  margin-right: 0;
}

.upload-img-box .afterSale-close-img {
  position: absolute;
  top: -20upx;
  left: 110upx;
  width: 50upx;
  height: 50upx;
  border: 5upx solid #fff;
  border-radius: 50%;
}

.upload-img-box .single .jiahao {
  font-size: 70upx;
  color: #999;
  font-weight: 100;
}

.upload-img-box .single .upload-word {
  font-size: 24upx;
  color: #999;
}

.upload-img-box .single-kuang {
  width: 150upx;
  height: 150upx;
  background: #f5f5f5;
  border-radius: 8upx;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.upload-img-box .single-num {
  margin-left: 10upx;
  font-size: 24upx;
  color: #999;
}

.order-flow-box {
  display: flex;
  flex-direction: column;
  padding: 30upx;
  box-sizing: border-box;
}

.flow-word {
  font-size: 24upx;
  color: #999;
  display: flex;
  flex-direction: column;
}

.mt25 {
  margin-top: 20upx;
}

.mt50 {
  margin-top: 30upx;
  margin-bottom: 20upx;
}

.order-confirm-box {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 160upx;
  background: #fff;
  padding: 0 30upx;
  box-sizing: border-box;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
}

.order-confirm-box .btn {
  width: 100%;
  height: 100upx;
  line-height: 100upx;
  background: #333333;
  font-size: 28upx;
  color: #FFEBC4;
  text-align: center;
}

.alert-box {
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
}

.afterSale-status-box {
  width: 100%;
  background: #fff;
  border-radius: 15upx 15upx 0upx 0upx;
}

.status-title {
  width: 100%;
  height: 140upx;
  background: #fff;
  border-radius: 15upx 15upx 0 0;
  font-size: 34upx;
  color: #333;
  text-align: center;
  line-height: 140upx;
}

.afterSale-status-box .item {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid #e5e5e5;
}

.afterSale-status-box .item:last-of-type {
  border-bottom: none;
}

.afterSale-status-box .item-box {
  padding: 0 0 60upx 0;
}

.afterSale-status-box .status-select-title {
  padding: 0 0 0 30upx;
  box-sizing: border-box;
  font-size: 28upx;
  color: #333;
}

.afterSale-status-box .status-select-img {
  width: 40upx;
  height: 40upx;
  margin: 30upx;
  box-sizing: border-box;
}

.afterSale-status-box .status-btn {
  width: 100%;
  height: 100upx;
  line-height: 100upx;
  background: #333333;
  font-size: 28upx;
  color: #FFEBC4;
  text-align: center;
}
</style>
